HomeTabs.tsx 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. "use client";
  2. import { ConfigType } from "@/api/config";
  3. import { GroupType } from "@/api/home";
  4. import Box from "@/components/Box";
  5. import { useRouter } from "@/i18n/routing";
  6. import { Toast } from "antd-mobile";
  7. import clsx from "clsx";
  8. import { useTranslations } from "next-intl";
  9. import { FC, useState } from "react";
  10. import { Swiper, SwiperSlide } from "swiper/react";
  11. import HomeGames from "./HomeGames";
  12. const buttonGroup = [
  13. {
  14. icon: "qianbao3",
  15. category_name: "sixth",
  16. isHot: false,
  17. url: "/freeGames",
  18. locale: true,
  19. lock: false,
  20. },
  21. {
  22. icon: "qianbao3",
  23. category_name: "seventh",
  24. isHot: false,
  25. url: "/replayGames",
  26. locale: true,
  27. lock: false,
  28. },
  29. {
  30. icon: "liwulipinjiangpin",
  31. category_name: "first",
  32. isHot: true,
  33. url: "/promo",
  34. locale: true,
  35. lock: false,
  36. },
  37. // {
  38. // icon: "pro-youxi1",
  39. // category_name: "second",
  40. // isHot: false,
  41. // url: "/gameList/110",
  42. // locale: true,
  43. // lock: true,
  44. // },
  45. {
  46. icon: "huodongyule",
  47. category_name: "third",
  48. isHot: false,
  49. url: "/sports",
  50. locale: true,
  51. lock: false,
  52. },
  53. {
  54. icon: "shipin",
  55. category_name: "fourth",
  56. isHot: false,
  57. url: "/gameList/112",
  58. locale: true,
  59. lock: true,
  60. },
  61. {
  62. icon: "yingyong",
  63. category_name: "Fifth",
  64. isHot: false,
  65. url: "/gameList/110",
  66. locale: true,
  67. lock: true,
  68. },
  69. ] as const;
  70. type TabItemType = (typeof buttonGroup)[number] & GroupType;
  71. const TabItem = ({
  72. item,
  73. active,
  74. onClick,
  75. }: {
  76. item: TabItemType;
  77. active?: boolean;
  78. onClick?: (item: TabItemType) => void;
  79. }) => {
  80. const t = useTranslations("ButtonGroup");
  81. const router = useRouter();
  82. const handler = (item: TabItemType) => {
  83. if (!item.locale) {
  84. onClick && onClick(item);
  85. return;
  86. }
  87. if (item.lock) {
  88. Toast.show("It is under development.");
  89. } else {
  90. router.push(item.url);
  91. }
  92. };
  93. const cls = clsx("pro-iconfont text-[0.14rem]", `pro-${item.icon}`);
  94. const cls2 = clsx("iconfont text-[0.145rem]", `icon-${item.icon}`);
  95. const rootCls = clsx(
  96. "relative mr-[0.06rem] flex h-[0.3rem] bg-[#3a3a3a] flex-1 cursor-pointer items-center" +
  97. " rounded-[0.05rem] px-[0.08rem] py-[0.03rem] text-[0.12rem] text-[#fff]",
  98. { "bg-primary-color": active }
  99. );
  100. return (
  101. <div className={rootCls} onClick={() => handler(item)}>
  102. <span className={item.icon === 'qianbao3' ? cls2 : cls}></span>
  103. <span className={"ml-[0.03rem] truncate"}>
  104. {item.locale ? t(item.category_name) : item.category_name}
  105. </span>
  106. {item.isHot && (
  107. <img
  108. className={"absolute -top-[0.12rem] right-0 h-[0.21rem] w-[0.21rem]"}
  109. src=""
  110. alt=""
  111. />
  112. )}
  113. </div>
  114. );
  115. };
  116. interface Props {
  117. tabs: GroupType[];
  118. config: ConfigType;
  119. }
  120. const Tabs: FC<Props> = (props) => {
  121. const { tabs, config = { show_free_game: 2, show_again_game: 2 } } = props;
  122. const newButtonGroup = buttonGroup.filter((item: any) => {
  123. if (item.url === "/freeGames" && config.show_free_game !== 1) {
  124. return false;
  125. }
  126. if (item.url === "/replayGames" && config.show_again_game !== 1) {
  127. return false;
  128. }
  129. return true;
  130. });
  131. const tabData = [...tabs, ...newButtonGroup];
  132. const [active, setActive] = useState<number>(0);
  133. const router = useRouter();
  134. const selectHandler = (item: TabItemType, index: number) => {
  135. if (item.bet_type === 2 || item.bet_type === 3) {
  136. router.push(
  137. `/gameList/?gameListFlag=${item.category[0].jump_id}&type=1&bet_type=${item.bet_type}`
  138. );
  139. return;
  140. }
  141. setActive(index);
  142. };
  143. const groupGames = tabs[active]?.category;
  144. return (
  145. <>
  146. <Box pt={false}>
  147. <Swiper slidesPerView={"auto"} centeredSlidesBounds>
  148. {tabData?.map((group, index) => (
  149. <SwiperSlide key={index} className={"max-w-fit pt-[0.1389rem]"}>
  150. <TabItem
  151. item={group as TabItemType}
  152. active={index === active}
  153. onClick={(event) => selectHandler(event, index)}
  154. ></TabItem>
  155. </SwiperSlide>
  156. ))}
  157. </Swiper>
  158. </Box>
  159. <HomeGames groupGames={groupGames} />
  160. </>
  161. );
  162. };
  163. export default Tabs;